<template>
  <div>
    <div>【数据传递信息】</div>
    <div ref="target" class="w-full h-full"></div>
  </div>
</template>

<script setup>
import { normalizeClass, onMounted, ref, watch } from "vue"
import * as echarts from 'echarts';

const props = defineProps({
  data: {
    type: Object,
    required: true
  }
})
console.log('1111', props.data)

let mChart = null

// 初始化 echarts 实例
const target = ref(null)
onMounted(() => {
  mChart = echarts.init(target.value)
  renderChart()
})

// 构建option配置对象

const renderChart = () => {
  const option = {
    xAxis: {
      show: false,
      type: 'value'
    },
    yAxis: {
      show: false,
      type: 'value'
    },
    series: [
      {
        // 用于展现节点以及节点之间的关系数据。
        type: 'graph',
        // 图的布局
        layout: 'none',
        // 使用二维的直角坐标系（也称笛卡尔坐标系）
        coordinateSystem: 'cartesian2d',
        symbolSize: 26,
        z: 3,
        // 边界标签文字
        edgeLabel: {
          normal: {
            show: true,
            color: '#fff',
            textStyle: {
              fontSize: 14
            },
            formatter: function (params) {
              let txt = ''
              if (params.data.speed !== undefined) {
                txt = params.data.speed
              }
              return txt
            }
          }
        },
        // 圆饼下文字
        label: {
          normal: {
            show: true,
            position: 'bottom',
            color: '#5e5e5e'
          }
        },
        // 边两端的标记类型
        edgeSymbol: ['none', 'arrow'],
        // 边两端的标记大小
        edgeSymbolSize: 8,
        // 圆数据
        data: props.data.relations.map((item) => {
          // id 为 0 ，表示数据中心，数据中心单独设置
          if (item.id !== 0) {
            return {
              name: item.name,
              category: 0,
              active: true,
              speed: `${item.speed}kb/s`,
              // 位置
              value: item.value
            }
          } else {
            // 数据中心
            return {
              name: item.name,
              // 位置
              value: item.value,
              // 数据中心圆的大小
              symbolSize: 100,
              // 圆的样式
              itemStyle: {
                normal: {
                  // 渐变色
                  color: {
                    colorStops: [
                      { offset: 0, color: '#157eff' },
                      { offset: 1, color: '#35c2ff' }
                    ]
                  }
                }
              },
              // 字体
              label: { normal: { fontSize: '14' } }
            }

          }
        }),
        // 线
        links: props.data.relations.map((item, index) => ({
          // 方向
          source: item.source,
          target: item.target,
          // 线上的文字
          speed: `${item.speed}kb/s`,
          // 线的样式  curveness  边的曲度，支持从 0 到 1 的值，值越大曲度越大。
          lineStyle: { normal: { color: '#12b5d0', curveness: 0.2 } },
          // 文字位置
          label: {
            show: true,
            position: 'middle',
            offset: [10, 0]
          }
        }))
      },
      {
        // 用于带有起点和终点信息的线数据的绘制
        type: 'lines',
        // 使用二维的直角坐标系
        coordinateSystem: 'cartesian2d',
        // z-index
        z: 1,
        // 线特效的配置
        effect: {
          show: true,
          // 是否平缓
          smooth: false,
          // 特效尾迹的长度
          trailLength: 0,
          symbol: 'arrow',
          color: 'rgba(55,155,255,0.5)',
          symbolSize: 12
        },
        // 线的样式
        lineStyle: {
          normal: {
            curveness: 0.2
          }
        },
        // 线的数据级，前后线需要重合。数据固定
        data: [
          [{ coord: [0, 300] }, { coord: [50, 200] }],
          [{ coord: [0, 100] }, { coord: [50, 200] }],
          [{ coord: [50, 200] }, { coord: [100, 100] }],
          [{ coord: [50, 200] }, { coord: [100, 300] }]
        ]
      }
    ]

  }
  // 通过 实例.setOptions(option)
  mChart.setOption(option)
}

// 监听数据变化更新柱形图
watch(
  () => props.data,
  () => {
    renderChart()
  }
)

</script>

<style lang="scss" scoped></style>